Method and device for the transmission of data in a television system

ABSTRACT

The invention concerns a method for transmitting binary data in a video transmission system. The method comprises the steps of providing ATVEF announcements on a first predefined IP multicast address; providing ATVEF trigger and/or content transmission on a first range of IP multicast addresses; providing non-ATVEF announcements on a second predefined multicast address different from said first address; and providing non-ATVEF data transmission on a second range of IP multicast addresses, exclusive of the first range. The invention also concerns an emitter and a receiver for implementing the method.

[0001] The invention concerns a method for transmitting data in a television system, as well as an emitter and a receiver in such a system. The invention applies in particular, but is not limited to, systems implementing the ATVEF specification.

[0002] Television receivers are being developed to host resident interactive services, transmitted for example through a bi-directional return channel or simply broadcast over the same channel as the video signal. In this context, ATVEF (Advanced TeleVision Enhancement Forum) specifies the use of a number of protocols such as IP multicast (Internet Protocol multicast) for transporting data for interactive television program enhancement services over a number of transmission media.

[0003] According to the ATVEF specification, when a service provider wishes to transmit an interactive service, he first has to transmit a message called an announcement, containing information describing the interactive service. This announcement is transmitted to a specific IP multicast address and to a specific port, known to all receivers (IP address 224.0.1.113 and UDP Port 2670).

[0004] Receivers compatible with the ATVEF specification continuously monitor this address/port couple. Their resident software modules retrieve the announcement, which contains a pair of IP addresses, one for the transmission of the interactive service (called the ‘content’), another one of the transmission of triggers. Triggers are messages for triggering a certain behavior of interactive services at predetermined moments.

[0005] Software modules resident in the receivers may require updates. For flexibility reasons, it should be possible to make such an update in remote fashion, i.e. to transmit the updated software modules to the receivers in situ. Such a transmission should obviously use some of the already available transmission media, such as the return channel (be it through the PSTN or the cable network, or another type of bi-directional communication means) or the television broadcast medium.

[0006] The ATVEF protocol stack (see figure la) cannot be used directly to transmit the update—or other types of binary data—, because the software in charge of retrieving the interactive service (e.g. a browser) is not able to interpret the content data which represents the resident software module update. This update is typically binary data, instead of the UHTTP data expected by the browser. This could result in unpredictable behavior at the receiver level. Modifying the browser to detect and process binary data would be impractical. In addition, transporting binary data using UHTTP is cumbersome, since this protocol has not been developed for such a purpose.

[0007] Nevertheless, it is desired to respect as much a possible the ATVEF protocol, to remain within the constraints defined by the broadcast tools.

[0008] The object of the invention is a method for transmitting binary data in a video transmission system comprising the steps of:

[0009] providing ATVEF announcements on a first predefined IP multicast address;

[0010] providing ATVEF trigger and/or content transmission on a first range of IP multicast addresses;

[0011] providing non-ATVEF announcements on a second predefined multicast address different from said first address;

[0012] providing non-ATVEF data transmission on a second range of IP multicast addresses, exclusive of the first range.

[0013] According to an embodiment of the invention, said system comprises an emitter comprising a data inserter for inserting ATVEF and non-ATVEF information into a transmission signal, said method further comprising the steps of:

[0014] providing ATVEF announcements and non-ATVEF announcements to the data inserter,

[0015] dynamic insertion of IP multicast addresses by the data inserter into the announcements, in accordance with the first and second ranges.

[0016] According to an embodiment of the invention, the method further comprises the step of splitting each of the first and/or the second range of IP multicast addresses into a third and a fourth range, where the third range is reserved for automatic address determination by the data inserter, and the fourth range is reserved for addresses which are predefined in the announcements provided to the data inserter.

[0017] According to an embodiment of the invention, ranges are distinguished by different IP address ranges, different port ranges or both.

[0018] According to an embodiment of the invention, at the level of a receiver, the method further comprises the steps of:

[0019] receiving a non-ATVEF announcement announcing transmission of receiver software update data, said announcement containing an IP multicast address on which signaling data describing the update data transmission is to be sent;

[0020] listening to the address specified in the announcement;

[0021] retrieving the signaling data and storing it in a memory which is not erased during download of the update data;

[0022] launching of a loader program;

[0023] having the loader program retrieve the stored signaling data; and

[0024] proceeding with the download of the update data based on the stored signaling data.

[0025] Another object of the invention is an emitter device for broadcasting announcements in a transmission system compatible with ATVEF transmissions, characterized in that it comprises means for transmitting ATVEF announcements on a first predefined IP multicast address, ATVEF trigger and/or content data on a first range of IP multicast addresses, binary data announcements on a second predefined IP multicast address different from the first predefined address and binary data on a second range of IP multicast addresses, wherein the first and second address ranges are exclusive of each other.

[0026] According to an embodiment of the invention, the emitter comprises means for receiving an announcement, for determining whether the announcement comprises a predetermined IP multicast address in a first range, and in the negative, for selecting an IP multicast address in a second range, distinct from the first range, and for inserting the selected IP multicast address into the announcement.

[0027] Another object of the invention is a receiver in an ATVEF compatible transmission system, characterized in that it comprises a memory for storing a first predefined IP multicast address for receiving ATVEF announcements, and a second predefined IP multicast address for receiving announcements relating to the transmission of binary data, where the first and second addresses are distinct.

[0028] According to a variant embodiment, the receiver further comprises a memory for receiving a third multicast address on which binary data transmission is announced, said memory being such as to maintain the multicast address during a receiver reboot process, said receiver further comprising means for listening to the third multicast address in the memory after reboot for downloading the binary data from said third multicast address.

[0029] According to an embodiment, the third multicast address on which binary data transmission is announced is provided in signaling data announced on said second multicast address.

[0030] According to an embodiment, the downloaded binary file is a complete system update.

[0031] Other characteristics and advantages of the invention will appear through the description of a detailed, non-limiting embodiment, explained with the help of the attached drawings, among which:

[0032]FIG. 1a (prior art) represents an ATVEF protocol stack;

[0033]FIG. 1b represents a protocol stack of a device according to the embodiment;

[0034]FIG. 2 represents the software structure of a receiver, as well as different applications and tasks and their evolution upon reception of an announcement;

[0035]FIG. 3 is a flowchart of the processing of announcements and data by a receiver according to the invention;

[0036]FIG. 4 is a flowchart of the processing of announcements in a broadcast server;

[0037]FIG. 5 is a schematic diagram illustrating the principle of acquiring an IP multicast address in a first step when the receiver is in nominal mode and using the stored IP multicast address in a second step during which the receiver is in a loader mode;

[0038]FIG. 6 is a schematic diagram of a network comprising an emitter and receivers according to the present embodiment.

[0039] In the figures, the symbol ‘@’ is used to designate an address.

[0040] More information concerning the ATVEF specification can be found in the document “Enhanced Content Specification” ATVEF (Advanced TeleVision Enhancement Forum) Specification v 1.1 r26. This document is available for example on the ATVEF website (www.atvef.com).

[0041] Reference is also made to the document ‘SDP: Session Description Protocol’, Internet Society, Network Working Group, RFC 2327 of Apr. 1998, available at ftp.isi.edu/in-notes/rfc2327, txt.

[0042] Announcements according to the ATVEF specification follow the format described in the SDP document mentioned in the previous paragraph, though ATVEF imposes some restrictions for some parameters. Parameters used in an SDP announcement according to the ATVEF specification are as follows:

[0043] Session Description

[0044] v=protocol version, equal to 0

[0045] o=username, session identifier, version, network type (equal to IN in the present case), address type (equal to IP4 in the present case), ipaddress

[0046] s=session name

[0047] i=session information (optional)

[0048] u=Universal Resource Identifier (URI) of a description of the enhancement (optional)

[0049] e=email address

[0050] p=phone number (at least one of the e and p parameters is required)

[0051] b=CT:number (bandwidth information)

[0052] c=connection information

[0053] The following session attributes can or must be used:

[0054] a=UUID:UUID (Universally Unique Identifier: unique enhancement identifier-optional)

[0055] a=type:tve

[0056] a=lang, a=sdplang (optional language attributes)

[0057] a=tve-type:<types>(optional)

[0058] a=tve-size: Kbytes

[0059] a=tve-level:x (optional)

[0060] a=tve-ends:seconds (optional)

[0061] Media description

[0062] m=(media name and transport address)

[0063] Time description

[0064] t=(time during which the session is active)

[0065] As has already been mentioned in the introduction, ATVEF announcements are sent to a predefined IP address (224.0.1.113) and a predefined UDP port number (2670).

[0066] The parameter ‘c’ of an announcement indicates to which address content and triggers will be sent, while the parameter ‘m’ indicates on which port they will be sent. Triggers and content may be sent on different ports at the same address, as well as on different addresses.

[0067] The present embodiment concerns an analog television system in which the vertical blanking interval lines of the analog video signal are used to transmit digital data. Modulation of this kind of data on an analog television signal is well known per se.

[0068]FIG. 1b is a diagram of the protocol stack used by a receiver in conformance with the present embodiment. Compared to the ATVEF stack of FIG. 1a, the UHTTP layer has been replaced by a proprietary layer. The stack includes UDP (User Datagram Protocol) over IP (Internet Protocol), SLIP (Serial Line Internet Protocol) and IDL-B, as defined in ETS 300 708.

[0069] The role of the proprietary layer is to manage binary data downloading. The binary data to be downloaded is split into sections having the size of IP packet payloads, i.e. 1472 octets. The layer assembles the different sections it receives in the right order. If a section contains uncorrectable errors, then the proprietary layer waits for a next transmission (see below) and inserts it at its proper place.

[0070] The proprietary layer also retrieves date/time information and announcements relating to binary data downloads and date/time information.

[0071] Enhancements and binary data are usually sent repeatedly, in order to enable receivers to access the corresponding data even when they do not listen from the beginning of the transmission, and in order to retrieve packets which were previously received with uncorrectable errors.

[0072] According to the present embodiment, in order to announce the transmission of binary data, an announcement of the SDP format is made at another address and port than the address and port used by the ATVEF announcements. Accordingly, as an example, the receiver listens to the address 235.0.1.113, port number 2670, to detect these novel types of announcements. In parallel, the receiver continues to listen to the standard ATVEF announcement address and port.

[0073]FIG. 2 is a diagram of an example of the applications and tasks that a receiver according to the present embodiment runs in parallel according to the present embodiment. Of course, other applications and tasks may also run, but are not directly relevant to the present embodiment. The receiver listens to six different IP multicast addresses, numbered A1 to A6. An IP multicast address comprises an IP address and a port number. An ATVEF announcement is sent to the well-known ATVEF address/port couple A1 as already described above. ATVEF content and triggers (‘ATVEF data’) is sent to two different address/port couples, A3 and A4, which are specified by the ATVEF announcement. Two different non-ATVEF announcements are sent to predefined, fixed address/port A2. The first one indicates an address/port A5 for retrieving date and time information, while the second one indicates an address/port A6 for retrieving the binary data.

[0074] Applications of FIG. 2 act upon a socket layer 4 to listen to the required IP multicast addresses. The socket layer 4 operates over an operating system 5 including a VBI Driver (which is not illustrated). The Vertical Blanking Interval (VBI) driver retrieves data from the VBI of the incoming analog video signal. Of course, in case another transmission path were used (e.g. all digital television signal such as an MPEG II Transport Stream), another driver than the VBI Driver would be used. The retrieved data is under a packet format called IDLB. The driver extracts the payload from these packets and applies an error correction process. The payload is a SLIP-format stream which enables the driver to identify and separate IP packets. Once the SLIP layer has been removed and the IP packets have been reconstructed, the driver hands these packets over to the upper layers in charge of de-encapsulating the IP and UDP layers. The browser 1 and the other applications are clients of the socket layer 4 which enables them to listen to an IP address and a UDP port in order to retrieve the transmitted content.

[0075] The upper part of FIG. 2 will be described first. The upper and lower parts show the receiver's state at different moments in time.

[0076] The receiver runs a browser 1 in charge of retrieving respectively the ATVEF announcements, content and triggers and listens respectively to addresses A1, A3, A4, which the browser 1 has programmed at the socket level). In FIG. 2, it is supposed that at least one announcement has already been received. The browser may also listen to other addresses, which are not shown on FIG. 2. A first task 2 (‘Binary data fetching manager’) is in charge of retrieving the non-ATVEF announcements sent on address A2. A second task 3 (‘Code download signaling data retriever’) is used to retrieve the binary file itself on an address A6. The address A6 has previously been specified in a binary announcement on address A2. Two different tasks are used to retrieve the update announcement and the update file itself: this avoids having to sort the incoming data relating to these addresses.

[0077] The second task 3 need not be active all the time. It can be triggered by the first task 2, upon reception of an announcement relating to the kind of data retrieved by the second task 3.

[0078] According to the present embodiment, the ‘i’ field of an announcement is used to inform the task 2 of the nature of the data to be transmitted. For example, ‘i’ is equal to ‘code download’ for the transmission of binary data, and equal to ‘date&time’ for the transmission of the date and time information.

[0079] Contrary to ATVEF announcements, the announcement according to the present embodiment contains only one address and associated port value, to indicate to the receiver where to listen for the transmission of the binary data (code update, time, or other).

[0080] According to the present embodiment, such an announcement contains the following parameters relating to the address and port of the update file:

m=data 22814 tvpe-file c=IN IP4 235.37.32.27.

[0081] Other parameters are similar to those used in ATVEF announcements. This is given as an example: other values may be used as well.

[0082] As an example, a non-ATVEF announcement contains the following fields:

[0083] “v=0” see ATVEF

[0084] “i=XXX” see below

[0085] “a=UUID:XXX” see ATVEF

[0086] “a=tve-ends:XXX” or “t-start stop” see ATVEF

[0087] “m=data XXX tve-file” see above and ATVEF

[0088] “c=IN IP4 XXX” see above and ATVEF

[0089]FIG. 2 also illustrates the dynamics of announcement handling in the receiver. The upper part of FIG. 2 shows the receiver's task at a time t. At this time, the browser 1 listens to its predetermined ATVEF announcement address A1, and to two further addresses for content (A3) and triggers (A4). The binary data fetching module 2 listens to the address corresponding to binary data announcements.

[0090] At a given time, a binary announcement concerning the transmission of date and time is received by the binary data fetching module 2. This announcement contains an IP multicast address A5 on which data and time information is due to be transmitted. As illustrated by the lower part of FIG. 2, a third task 6, named ‘Date and time data retriever’ is launched, in order to listen to the address A5 specified in the announcement.

[0091]FIG. 3 is a flowchart which further illustrates the processing of ATVEF and non-ATVEF announcements and data in the receiver.

[0092] It must be noted that from the point of view of the implementation, the test of whether an announcement is an ATVEF announcement or not corresponds in fact to the filtering carried out using the different IP multicast addresses.

[0093] The field “a=UUID” serves to identify the announcement. If the proprietary layer, in its role of binary data fetching module, already received an announcement with the same UUID value although the expiration date of this announcement has not yet been reached, the new announcement is ignored. It is up to the operator to modify the UUID value in order to inform receivers of an announcement content change. This mechanism avoids having to further process announcements if their UUIDs correspond to those of already existing announcements.

[0094] When preparing an announcement, the service provider or the broadcaster's emitter selects the address values for data transmission in a certain range. According to the present embodiment, one such range is reserved for ATVEF transmissions, while another such range is reserved for non-ATVEF transmissions (e.g. software module updates according to the present example). This avoids having ATVEF data sent to non-ATVEF addresses and vice-versa.

[0095] Through this mechanism, different kinds of services may easily be multiplexed.

[0096]FIG. 4 is a flowchart of the announcement creation process in a server, showing how IP multicast addresses are automatically selected and inserted into announcements by the emitter in the absence of preset addresses.

[0097] In a preferred embodiment, the broadcaster receives the ATVEF or non-ATVEF announcements and dynamically adds through its emitter the content, trigger or binary data transmission addresses according to the predefined ranges.

[0098] As an example, the following address range is used for sending ATVEF enhancements on manually attributed addresses:

[0099] 224.0.0.0 to 224.0.1.112 port numbers 0 to 2669.

[0100] The following address range is used for sending ATVEF enhancements on automatically attributed addresses:

[0101] 224.0.1.114 to 234.255.255.255, port numbers 2671 to 65535.

[0102] The following address range is used for sending binary files on manually attributed addresses:

[0103] 235.0.0.0 to 235.0.1.112, port numbers 0 to 2669.

[0104] The following address range is used for sending binary files on automatically attributed addresses:

[0105] 235.0.1.114 to 239.255.255.255, port numbers 2671 to 65535.

[0106] Manually attributed addresses are addresses which are predetermined in announcements received by the emitter from e.g. the service provider, i.e. the emitter does not itself select such addresses, as opposed to announcements were such a choice is made automatically by the emitter, when at least one address is missing in an announcement. Different address ranges are used to avoid having the emitter pick an address which has already been defined manually in another announcement.

[0107] According to a variant embodiment, the address ranges used for ATVEF and non-ATVEF data transmissions are the same or at least overlap to a certain extent, but the port number ranges attributed to each kind of data transmission do not overlap. In other words, there will still be different IP multicast address ranges.

[0108] The two address ranges may be modified. In this case, an update mechanism is put in place at the receiver.

[0109] A variant embodiment, illustrated by FIG. 5, will now be described. This embodiment concerns the case in which the binary data to be downloaded may influence—and in particular interrupt—certain processes of the receiver.

[0110] One can consider a receiver in which downloading of executable code, for example all updatable code stored in a flash memory of the receiver, is to be performed. The receiver comprises a loader program 7 in order to perform the download. This program is stored in ROM, since all code stored in the flash memory is to be replaced.

[0111] The process in such a case is the following:

[0112] When the binary data fetching module receives a non-ATVEF announcement for an update, it starts a specific task (the code download signaling retriever of FIG. 2), which listens to an address specified in the update announcement. The code to be downloaded is not sent to this address, eventually with other signaling information describing the download to be carried out. Instead, this address receives a stream which describes the upcoming download, and in particular a download address. The code download signaling data retriever task stores this address in a predefined location in the flash memory 8 of the receiver, this location being protected from being erased during the subsequent download. When the download is to begin, the task reboots the decoder. The loader 7 is then launched. This program fetches the download address from the flash memory and downloads the code from this address. This update process may also be used in other environments than that of the present embodiment (i.e. environments not related to ATVEF).

[0113]FIG. 6 is a schematic diagram of a network comprising an emitter 51, and a plurality of receivers 52 i. The emitter comprises a video signal source 53, a data inserter 54 controlled by a broadcast server 61. The broadcast server 61 is connected to a database 55, containing ATVEF and non-ATVEF data and announcements. The data inserter inserts data into the VBI lines of the video signal in an appropriate format, under control of the broadcast server, which defines timing and allocates signal resources. Data in database 55 may be provided by different sources, in particular a service provider 56. The broadcast server 61 automatically selects addresses as explained above, in case such an automatic selection is required. Receivers also comprise a microprocessor 57, a ROM 58 with a loader program 59 mentioned above, as well as a register or memory 60 adapted to hold a multicast address during receiver reset and/or reboot and/or power loss.

[0114] Although the present embodiment mainly concerns ATVEF-type protocols, the invention is not limited to that environment. In particular, other announcement formats than those of the ATVEF or SDP announcements may be used. The split multicast address ranges according to data type in particular constitutes an invention which may be employed in an other environment.

[0115] Lastly, although the embodiment above concerns an implementation using the vertical blanking interval of an analog video signal to transmit the enhancement and update data, the invention can easily be applied within other system, in particular all-digital transmission systems.

[0116] The emitter and receiver in the described system both comprises processing means such as a microprocessor (reference 57 in receivers of FIG. 5) and memory, for processing and respectively sending or receiving announcements, triggers, enhancement content and binary data. 

1. Method for transmitting binary data in a video transmission system comprising the steps of: providing ATVEF announcements on a first predefined IP multicast address; providing ATVEF trigger and/or content transmission on a first range of IP multicast addresses; providing non-ATVEF announcements on a second predefined multicast address different from said first address; providing non-ATVEF data transmission on a second range of IP multicast addresses, exclusive of the first range.
 2. Method according to claim 1, wherein said system comprises an emitter (51) comprising a data inserter (54) for inserting ATVEF and non-ATVEF information into a transmission signal, said method further comprising the steps of: providing ATVEF announcements and non-ATVEF announcements to the data inserter (54), dynamic insertion of IP multicast addresses by the data inserter (54) into the announcements, in accordance with the first and second ranges.
 3. Method according to claim 2, further comprising the step of splitting each of the first and/or the second range of IP multicast addresses into a third and a fourth range, where the third range is reserved for automatic address determination by the data inserter (54), and the fourth range is reserved for addresses which are predefined in the announcements provided to the data inserter.
 4. Method according to one of the claims 1 to 3, wherein ranges are distinguished by different IP address ranges, different port ranges or both.
 5. Method according to one of the claims 1 to 4, comprising, at the level of a receiver, the steps of: receiving a non-ATVEF announcement announcing transmission of receiver software update data, said announcement containing an IP multicast address (A6) on which signaling data describing the update data transmission is to be sent; listening to the address (A6) specified in the announcement; retrieving the signaling data and storing it in a memory which is not erased during download of the update data; launching of a loader program; having the loader program retrieve the stored signaling data; and proceeding with the download of the update data based on the stored signaling data.
 6. Emitter device (51) for broadcasting announcements in a transmission system compatible with ATVEF transmissions, characterized in that it comprises means for transmitting ATVEF announcements on a first predefined IP multicast address, ATVEF trigger and/or content data on a first range of IP multicast addresses, binary data announcements on a second predefined IP multicast address different from the first predefined address and binary data on a second range of IP multicast addresses, wherein the first and second address ranges are exclusive of each other.
 7. Device according to claim 6, further comprising means (54, 55) for receiving an announcement, for determining whether the announcement comprises a predetermined IP multicast address in a first range, and in the negative, for selecting an IP multicast address in a second range, distinct from the first range, and for inserting the selected IP multicast address into the announcement.
 8. Receiver (52 i) in an ATVEF compatible transmission system, characterized in that it comprises a memory for storing a first predefined IP multicast address for receiving ATVEF announcements, and a second predefined IP multicast address for receiving announcements relating to the transmission of binary data, where the first and second addresses are distinct.
 9. Receiver according to claim 8, further comprising a memory (60) for receiving a third multicast address on which binary data transmission is announced, said memory being such as to maintain the multicast address during a receiver reboot process, said receiver further comprising means (57, 58, 59) for listening to the third multicast address in the memory after reboot for downloading the binary data from said third multicast address.
 10. Receiver according to claim 9, wherein the third multicast address on which binary data transmission is announced is provided in signaling data announced on said second multicast address.
 11. Receiver according to claim 10, wherein the downloaded binary file is a complete system update. 